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IA RASPBERRY PI 
RESA CHIARA 


GENERA IMMAGINI SENZA VIOLARE IL COPYRIGHT, AGGIUNGI 
VOCI NATURALI AL TUO LEGGI SCHERMO E INCONTRA UN 
CANE ROBOT NELLA NOSTRA GUIDA AGLI 
STRUMENTI DI MACHINE LEARNING PER RASPBERRY PI 


K.G. 
Orphanides 


K.G. è una scrittrice 
e sviluppatrice 


@owlbear 
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1 machine learning non è tutto un chiacchierare 

con i chatbot e generatori di immagini che 

violano il copyright, ma se avessi pensato così, 
saresti perdonato, a causa dell’hype attuale sulla 
intelligenza artificiale. In questo speciale, 
cercheremo le opzioni migliori per progetti che 
sfruttano il machine learning, giocattoli divertenti e 
strumenti veramente utili. 

Abbiamo già esaminato la creazione di chatbot 
(Costruisci il tuo Chatbot GPT, magpi.cc/129), 
utilizzando popolari strumenti online come i modelli 
GPT non molto open di OpenAI, oppure chatbot che 
utilizzano modelli completamente locali e incentrati 
sulla privacy, come quello della Stanford University 
Alpaca (perfezionato da LLaMA di Meta). 

Alcuni LLM (modelli linguistici di grandi 
dimensioni) includono contenuti liberamente 
accessibili in internet, incluse le pagine web 
contenenti materiale protetto da copyright, 
repository GitHub che non hanno rispettato le loro 
licenze, e sono stati addirittura trovati dati personali 
— il dataset di allenamento di LLaMA 2 è stato infatti 
cancellato. 

In questo contesto eviteremo modelli con 
funzionalità problematiche e faremo del nostro 
meglio per assicurarci di non utilizzare qualsiasi 
altro modello che contenga spiacevoli sorprese. 
Abbiamo invece cercato progetti open e di pubblico 
dominio che possono essere eseguiti localmente sul 
tuo hardware Raspberry Pi. 

Questo approccio ci permette di capirne di più sul 
machine learning e sugli strumenti di intelligenza 
artificiale mentre minimizziamo i potenziali danni. 


L'etica della IA 


Si è parlato molto di un'ipotetica minaccia che una 
IA generale (il termine popolare per una “vera” 
intelligenza artificiale - comunque tu scelga di 
definirla) potrebbe rappresentare per l’esistenza 
dell’umanità. 

Questa è un po’ una cortina fumogena per i veri 
problemi etici con cui gli utenti nel campo del 
machine learning avranno a che fare: l'elevato 
consumo energetico necessario per l'allenamento 
delle IA e nell’utilizzo di modelli basati su cloud; 
uso insostenibile dell'acqua da parte dei data center 
dove sono allenate e utilizzate; sfruttamento dei 
lavoratori sia nel labeling dei dati di allenamento 
che nella moderazione dei contenuti per sistemi 
live e per l’abuso di copyright sotto forma di dati, 
accessibili da internet, usati per addestramento del 
‘modello ma senza considerarne i termini della 
licenza. 

Gli utenti sono portati ad aspettarsi risposte 
autorevoli, e molti sembrano assumere che gli LLM 
| in particolare, conterranno informazioni attuali, 
‘anche se non possono riportare nulla di ciò che è 
accaduto dopo la data dei dati di addestramento del 
modello. 


2024 


Ancora più significativo, quel che fanno gli LLM è 
posizionare le parole in un ordine probabile basato 
sulla loro formazione: potresti averli sentiti definire 
“pappagalli stocastici”. Agli LLM non vengono 
forniti dati di formazione etichettati ma piuttosto di 
una vasta gamma di scritti e di pratiche emulando i 
modelli in esso contenuti. 

Gli LLM creano probabili sequenze di testo, il 
risultato di un processo formativo in cui il modello si 
cimenta per prevedere con precisione la parola 
successiva in un intervallo vasto di testi. Quello che 
sputano può essere divertente e addirittura 
impressionante, ma un LLM non può analizzare cosa 
stai chiedendo, o la sua risposta. Quindi vediamo 
avvocati citare casi che non esistono, chatbot che 
sputano fuori storie con falsi ricordi di atti criminali, 
raccomandano pacchetti software inventati che 
introducono vulnerabilità nel blockchain o 
semplicemente che ripetono popolari idee sbagliate e 
risposte plausibili ma imprecise a sfortunati utenti 
che li scambiano per un motore di ricerca o per un 
archivio di informazioni. 
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ZH COME USARE GLI STRUMENTI DI 
MACHINE LEARNING SENZA ESSERE 
GOFFAMENTE POCO ETICO EM 


Riduzione del danno 
Quindi, come usare gli strumenti di machine learning 
senza essere goffamente poco etico? 

Per cominciare, eseguiremo tutto localmente sul 
Raspberry Pi. Ciò limita immediatamente il tuo 
consumo a circa 6W (con Raspberry Pi 5) e ti assicura 
di poter tenere i tuoi dati per te. 

Faremo del nostro meglio per utilizzare modelli e 
progetti di machine learning che utilizzano solo dati 
di pubblico dominio o raccolti consensualmente, dati 
di allenamento, ed evidenziare eventuali problemi 
con gli altri menzionati. Allo stesso modo daremo 
priorità ai modelli aperti, dove sono accessibili al 
pubblico sia i dati che le metodologie di training, 
piuttosto che scatole nere opache. 

E anche se è difficile evitare di menzionare almeno 
un paio di colossi tecnologici del machine learning, 
vogliamo esplorare progetti più importanti, 
ingegnosità su piccola scala rispetto ai profitti 
speculativi e con l’influenza delle grandi aziende 
tecnologiche. 

Anche se “intelligenza artificiale” è nella migliore 
delle ipotesi un termine improprio, le tecnologie che 
vengono raggruppate sotto questo nome sono spesso 
affascinanti. Vale anche la pena capire cosa c'è dietro 
l'ultima mania che sta investendo il settore, e non c'è 
modo migliore per imparare che fare. 


Attenzione! 
Copyright 


Abbiamo utilizzato modelli 
liberi da copyright per la 
generazione delle immagini di 
questo speciale, ma la 
maggior parte degli altri 
modelli diffusi sono stati 
addestrati con scraping 
senza permesso e 
potrebbe compromettere i 
diritto d'autore di artisti in vita. 
Leggi la sezione Text e 
data mining per ricerche non 
commerciali. 


magpi.cc/copyright 
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PROGETTI TA 
IN PRIMO PIANO 


QUESTE REALIZZAZIONI AIUTANO A PORTARE 
L'INTELLIGENZA DELLA IA NEL MONDO REALE 


magpi.cc/coral 

magpi.cc/teachmachine 
L'acceleratore USB di Coral ti consente di creare 
funzionalità di intelligenza artificiale nei progetti 
Raspberry Pi. L'acceleratore è costruito attorno al chip 
Edge TPU di Google, un ASIC che accelera 
notevolmente le prestazioni di rete neurale sul 
dispositivo. 
Abbiamo usato Coral per costruire una Teachable 
Machine, un dispositivo a cui può essere insegnato a 
riconoscere gli oggetti, utilizzando Raspberry Pi, Coral 


USB e una telecamera Raspberry Pi per un sistema 
completo perfetto per eseguire attività complesse di 
visione artificiale come il riconoscimento degli oggetti. 
Poiché l'acceleratore è in funzione localmente, non è 
necessario connettersi a un cloud o condividere dati 


protetti su Internet. Funziona anche con una latenza 
inferiore rispetto a una connessione cloud, eseguendo 
il rilevamento degli oggetti quasi in tempo reale. 


ps ille 


& fm 


magpi.cc/braincraft 


Costruito per Raspberry Pi 4, Braincraft HAT di 
Adafruit è un kit piuttosto completo per il machine 
learning. Include uno schermo TET 240x240 da 1,54 
pollici come display, un joystick per navigare tra le 
opzioni visualizzate su di esso, una ventola di 
raffreddamento, tre LED controllabili, oltre a porte 
per altoparlante, cuffie e microfono per aiutarti a 
creare strumenti di sintesi vocale o progetti di 
assistenza domestica. Non c'è nessuna fotocamera 
integrata, ma include uno slot per collegarne una, 
così come una serie di altri dispositivi IC2 e JST 
STEMMA. 

Adafruit pubblica una serie di progetti mirati a 
Braincraft e sta attualmente aggiornando le guide e il 
software per supportare Raspberry PI OS Bookworm. 
La versione legacy di Raspberry Pi OS Bullseye, che è 
nota per essere stabile con l'HAT, è disponibile sia 
tramite Raspberry Pi Imager che tramite download 
diretto. 


Vizy Camera 


pe 
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magpi.cc/xgo2 
I cani robot XGO Mini 2 e Lite 2 di Luwu Dynamics 
sembrano la versione da scrivania del robot Spot di 
Boston Dynamics. Il robot può essere indirizzato da 
una varietà di microcontrollori e computer a scheda 
singola, ma la configurazione predefinita utilizza 
Raspberry Pi CM4. 

Oltre alle opzioni di controllo manuale, ha un set 
di routine comportamentali pre-programmate che 
puoi richiamare, incluso il riconoscimento degli 
oggetti utilizzando il sistema di rilevamento oggetti 
in tempo reale Yolo, il riconoscimento dei comandi 
vocali e si sforza di riconoscere di genere, emozioni 
e gesti. Tutti questi comportamenti sono gestiti da 
una serie di script Python e dalle relative librerie, 
che lo rendono davvero facile da personalizzare. 

Se non vuoi tuffarti immediatamente negli script di 
XGO, sono anche disponibili una serie di interfacce 
di programmazione e librerie personalizzate per 
controllare il corpo del cyberdog. Le opzioni 
spaziano da un'app per smartphone di controllo 
remoto a un'interfaccia di programmazione a 
blocchi basata su Python accessibile tramite un 
browser web. 
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TRASCRIZIONE E 
SINTESI VOCALE 


no degli sviluppi veramente più vantaggiosi 

derivanti dal machine learning è la capacità 

di eseguire strumenti offline in grado di 
fornire trascrizioni testuali sofisticate e accurate di 
audio parlato e in grado di leggere il testo per te. 

Sebbene quest’ultimo abbia purtroppo portato ad 

un boom di fastidiosi video con voce sintetica, è 
davvero utile quando è sotto il tuo controllo. 
Installeremo Speech Note (magpi.cc/speechnote), 
un potente strumento di sintesi vocale neurale text- 
to-speech (TTS), speech-to-text (STT) e di 
traduzione automatica che viene eseguito 
interamente a livello locale per garantire la privacy 
e configureremo lo screen reader Orca con Piper TTS 
per dare allo strumento di accessibilità un aspetto 
più moderno. Per prima cosa configureremo Flatpak 
e installeremo Speech Note tramite il terminale. 


Trascrizione note vocali 


$ sudo apt install flatpak 
$ flatpak remote-add --if-not-exists flathub 


https://flathub.org/repo/flathub.flatpakrepo 


Ora riavvia Raspberry Pi, quindi apri un 
Terminale e digita: 


$ flatpak install speechnote 


Dì "sì" per confermare che desideri utilizzare il 
riferimento suggerito, che desideri installarlo e 
desideri procedere con le modifiche suggerite 
all'installazione del sistema. 

Apri SpeechNote dal menu Audio e Video, quindi 
vai al menu Lingue, cerca italiano (e qualsiasi altra 
lingua di cui potresti aver bisogno) e seleziona i 
modelli che desideri utilizzare. 

Whisper di OpenAI è open source e gli strumenti 
di trascrizione non trasportano il fardello della 
violazione della proprietà intellettuale dei 
generatori di testo o immagine, quindi English 
Whisper Small dovrebbe fare la magia per lo 
Speech To Text (in inglese). 

Sono disponibili numerosi modelli di sintesi 
vocale. Troviamo che Piper Alba Medium sia facile 
da ascoltare e convenientemente vicino alla cima 
della lista. 


Sono disponibili anche alcune opzioni di 
traduzione, ma questo elenco è limitato a solo una 
per coppia linguistica. Puoi provarli in base ai 
requisiti della tua traduzione: abbiamo installato 
dall'inglese al francese e dal francese all'inglese: 
quest'ultimo era disponibile solo quando abbiamo 
selezionato il francese nel primo passaggio di 
installazione della lingua. Sono disponibili anche 
alcuni correttori di punteggiatura, che possono 
essere utili per gli studenti di lingue. 

Scarica il seguente file di test, che è un discorso di 
quattro secondi: magpi.cc/audiotestwav. 

In Speech Note fai clic su File > Trascrivi un file e 
apri il file appena scaricato. La trascrizione inizierà 
automaticamente e il testo verrà visualizzato nel 
riquadro principale di Speech Note. 


Integrare Piper con Orca 

La sintesi vocale Piper è un chiaro miglioramento 
rispetto alle voci sintetizzate eSpeak che tutti 
conosciamo. Non è ancora disponibile come 
opzione predefinita per molti lettori di schermo, 
ma possiamo integrarlo con Orca, lo screen reader 
Linux più maturo. 

Usare Orca con Piper ha i suoi limiti, come le 
prestazioni di lettura relativamente lente quando 
si lavora in un terminale e si richiedono più 
risorse di sistema, ma la voce più naturale può 
rendere più piacevole lavorare se si interagisce 
principalmente con una GUI tramite tasti rapidi. 


$ sudo apt install orca 
$ cd Software 


$ git clone https://codeberg.org/ 
MightyOwlbear/rpi-piper-tools.git 
$ sh install-spd-piper.sh 


Inserisci la tua password per installare le 
dipendenze quando richiesto. 

Una volta installato, supponendo che l'audio di 
prova fosse prodotto, è il momento di configurare il 
lettore Orca per utilizzare Piper: 


Nello strumento di configurazione di Orca, 
seleziona la scheda Voce. In Sintetizzatore vocale, 
seleziona "voce predefinita generica piper" dal 


Maggio 
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WE screen Bender Preter.. [vl [Sprechi Note 


Voice Type Settings Giobal Valse Settings 


between peuses 


lappina 


Speech Note è una applicazione 


singola, completamente Locale per Stiamo utilizzando lo screen reader 
strumenti come trascrizione da Orca, a cui abbiamo aggiunto Piper 
Whisper, Piper TTS e traduzioni neural Text-To-Speech 


ZI INSTALLEREMO SPEECH NOTE, 
UNA RETE NEURALE CON SINTESI 
VOCALE TEXT-TO-SPEECH E 
TRADUZIONE AUTOMATICA gw 


Deseleziona l'opzione "Dividi il discorso in 

blocchi tra le pause" nella casella sulla destra, invece di 

quindi fai clic su Applica. Potresti voler modificare 

anche la velocità del parlato: ci piace metterla a 70. 
Ora sentirai una voce Piper chiamata Alan 

narrare le tue interazioni. Vale la pena notare che, Se stai avviando la GUI, dovrai cambiare la 

se sei un dattilografo veloce, Piper non sarà in configurazione per adattarla alle tue preferenze. In 


grado di tenere il passo con il testo inserito lettera un Terminale digita: 
per lettera allo stesso modo di eSpeak. 


Orca funziona sia con Xorg che con Wayland, ma 
abbiamo visto prestazioni leggermente migliori in 
X. Se lo stai avviando dalla riga di comando e avvii Vai a 6 Opzioni avanzate > A6 Wayland > X1 X11 
la GUI da lì, invoca semplicemente e seleziona OK. Riavvia per rendere effettive le 


modifiche alle impostazioni. 
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REALIZZA UN DIFFUSORE 
DI IMMAGINI CHE 
RISPETTI L'ARTISTA 


a generazione di immagini è un campo 
| La & 
“ni 


minato se speri di mantenere l'uso del 

machine learning etico ed economico, oltre 
che divertente. Servizi come Midjourney e Dall-e 
sono scatole nere per gli utenti (non puoi vedere 


| Cosa Serve 


» 8GB RAM (Nota che 
potrebbe non funzionare 


sui modelli da 4GB) cosa succede al loro interno). Acquistare tempo su 
Re a questi servizi è costoso sia per te, che per 
(minimo 64GB) l'ambiente in termini non solo, in primo luogo, di 


addestramento dei modelli, ma anche di 
alimentazione e raffreddamento dei data center 
dove vengono eseguiti. 
» Python 3.10.6 7 e. PS 
i RI È Molti generatori di immagini si basano anche sul 

(Nota: Le versioni più recenti a fi... : ; 

non supportano PyTorch) lavoro di artisti viventi, senza il loro consenso, 
rendendoli un grosso problema. Fortunatamente, 
stiamo iniziando a veder emergere modelli di 
generazione di immagini basati su materiale di 
pubblico dominio come gallerie di immagini 
condivise da musei e opere d'arte offerte dai loro 
autori volontariamente e preventivamente. 


ZILA GENERAZIONE DI IMMAGINI È 
UN CAMPO MINATO SE SPERI DI 
MANTENERE L'UTILIZZO DEL ML 
ETICO ED ECONOMICO n_A40 


Per questo tutorial, abbiamo sc 
Diffusion One (magpi.cc/mits odello 
text-to-image compatibile coi 
addestrato esclusivamente c 
pubblico dominio. La sua li 
violare il diritto d'autore 
modello e di non spacc 


È Prompt: ‘stampa come creazioni non b. 
xilografica ukiyo e 


» Mitsua Diffusion One 
magpi.cc/mitsua 


impressionista nello stile di Turner, 
o visibili attraverso le nuvole, illuminando la 
ilberi, fiume". Prompt negativo: "persone, animali" 


richiede di non 
i messa a punto del 
> immagini generate 
ull'AI. 


del Monte Fuji La libreria Diffuse ugging Face ci 

ricoperto con la consente di eseguir delli di diffusione — che 
neve, nello stile di o " 7 2 

Hokusai". funzionano riduce rumore finché non 
Prompt negativo: appare un' imm e soddisfa il prompt — su 


"persone, animali" 


quasi tutte le CP stiamo utilizzando Pi 5. 
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Prompt: "un dipinto dell'antico enorme tempio giappone: Prompt: "una pi ; rita rti, John 
, tempio di K i into imp Atkinson Grim alberi, Prompt negativo: 
persone, animali 


Prompt: "cielo notturno nello stile di Van Gogh. Le case a ri e di Mondrian, con 
città sono bili sotto e S o forme q e su uno 


sfondo bianco, alcuni riempiti di colore rosso, blu e ner. 
pittura ad olio’. Prompt negativo: "ume imali, 
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Imposta il tuo disco 
01 Avrai bisogno di un Raspberry Pi 5 da 8 GB 
(o di Raspberry Pi 4) con una scheda microSD da 64 
GB. Su una nuova installazione di Bookworm: lo 
useremo headless, quindi puoi disabilitare l'avvio 
della GUI o installare la versione Lite di Raspberry 
Pi OS. Prima di masterizzare l'immagine del OS su 
una scheda microSD con Raspberry Pi Imager, 
ricorda di abilitare SSH con l'autenticazione tramite 
password, imposta un nome host, un nome utente e 
la password e configura la LAN wireless se ne hai 
bisogno. 

Se hai installato la versione completa di Raspberry 
Pi OS con GUI, ti consigliamo disabilitarla. Accedi 
tramite SSH o apri un Terminale e digita: 


$ sudo raspi-config 
1 System Options > S5 Boot / Auto Login > B2 
Console Autologin 


Selezione Fine e premi Yes per riavviare 

02 Configura lo swap 

Se non hai almeno 8 GB di spazio swap - 
spazio di lavoro aggiuntivo sulla scheda microSD 
per quando si esaurisce la RAM — Diffusers fallirà 
nel riprodurre l'immagine dopo l'elaborazione. 
Tieni presente che questo può consumare la scheda 
microSD più velocemente di quanto ci si possa 
aspettare. 


$ sudo dphys-swapfile swapoff 


$ sudo nano /etc/dphys-swapfile 


In nano, modificheremo le voci swapsize e 
maxswap per darci 8 GB di swap e nessun limite 
sulla dimensione dello swap: 


CONF_SWAPSIZE=8192 
CONF_MAXSWAP= 


Premi CTRL + X e Y. Quindi, torna al prompt dei 
comandi: 


$ sudo dphys-swapfile setup 
$ sudo dphys-swapfile swapon 


$ reboot 
03, Clonazione su larga scala 
Ora, alcune dipendenze prima di iniziare. 


Innanzitutto, dovremo aggiungere a Git il 
supporto per file di grandi dimensioni: 


$ curl -s https://packagecloud.io/install/ 
repositories/github/git-1fs/script.deb.sh | 


sudo bash 
$ sudo apt install git-1fs 


Inizializzalo: 


$ git-1fs install 


Crea una directory per il nostro modello e scaricalo: 


$ mkdir -p Software/models && cd Software/ 
models 

$ git clone https://huggingface.co/Mitsua/ 
mitsua-diffusion-one 


Sebbene non particolarmente grande per gli 
standard dei modelli di diffusione, Mitsua 
Diffusion One ha comunque una stazza di circa 6 
GB, quindi questa operazione potrebbe richiedere 
del tempo. 


078 Devi tenerli separati 

Per utilizzare Hugging Face Diffusers, 
avrai bisogno di PyTorch, che richiede Python 
nella versione massima di 3.10.6, piuttosto vecchia 
rispetto all'attuale versione. Utilizzeremo pyenv 
per installarlo e il comando virtualenv per 
assicurarci di bloccare il nostro ambiente di lavoro 
sulla giusta versione di Python e mantenere tutte 
le dipendenze rilevanti isolate. Ciò garantisce che 
nulla di ciò che facciamo qui avrà un impatto su 
qualsiasi altra cosa abbiamo installato o sulle 
impostazioni predefinite del nostro software a 
livello di sistema. 


$ cd 


Maggio 


2024 


SPECIALE | MagPi a 


06 Python dipende da te 


Utilizzeremo pyvenv per installare la 
è versione giusta di Python, ma abbiamo alcune 
dipendenze da installare per prime. Le abbiamo 
divise in tre commenti per facilitare la copia, ma 
puoi unirli in un unico comando apt install se 
preferisci. 


$ sudo apt install zlibig zliblg-dev libssl-dev 
libbz2-dev libsqlite3-dev 


$ sudo apt install libedit-dev libncurses5-dev 
liblzma-dev 
$ sudo apt-get install libreadline-dev libffi-dev 


E adesso possiamo installare la versione corretta di 
Python, gestito da pyenv. 


$ curl https://pyenv.run | bash 
$ pyenv install 3.10.6 


Ti verrà richiesto di aggiungere scorciatoie al tuo 
profilo bash per richiamare pyenv dalla riga di 


comando. Ambiente virtuale 
Un altro passo importante per mantenere 
05 Aggiorna il tuo profi lo) separate più configurazioni Python: creeremo un 
Nel Terminale, digita: ambiente virtuale, in cui installeremo 


$ nano »/.bashrc 


Aggiungi il seguente blocco alla fine del file e 


$ pyenv virtualenv 3.10.6 venv_diffusion 


salva con CTRL+X. Ora lo attiveremo. Dovrai ripetere questo passaggio 
ogni volta che desideri utilizzare il nostro script per 
echo ‘export PYENV_ROOT="$HOME/.pyenv”? >> diffusion. 


=/.bashrc 


$ pyenv activate venv_diffusion 


echo ‘command -v pyenv >/dev/null || export 
PATH="$PYENV_ROOT/bin:$PATH”? >> -/.bashrc Il prompt dei comandi verrà ora contrassegnato 
echo ‘eval “$(pyenv init -)?? >> «/.bashrc (venv_diffusion). Installeremo il software di cui 
abbiamo bisogno per invocare il nostro modello. 


Ora modifica il file .profile: 
$ cd Software 
$ git clone https://codeberg.org/MightyOwlbear/ 


$ nano «/.profile 
Raspberry-Pi-5-Diffusion.git 


Come sopra, aggiungi questo blocco alla fine del $ cd Raspberry-Pi-5-Diffusion 
file e salva: $ nano python mitsua_app.py 


08 Quasi arrivati 
Immetti: 


$ cd Software 
$ git clone https://codeberg.org/MightyOwlbear/ 
Ora ricarica il tuo profilo bash, così: Raspberry-Pi-5-Diffusion.git 


$source +/.bashrc 


echo ‘export PYENV_ROOT=”$HOME/.pyenv”? >> 
-/.profile 


echo ‘command -v pyenv >/dev/null || export 
PATH=”$PYENV_ROOT/bin:$PATH”? >> «/.profile 
echo ‘eval “$(pyenv init -)?”? >> «/.profile 


$ cd Raspberry-Pi-5-Diffusion 
$ nano python mitsua_app.py 


CI 


"a 
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SPECIALE 


Top Tip 


Non scordare 
di attivare 


Digita pyenv 
activate venv_ 
diffusion per 
attivare il tuo 
ambiente virtuale. 


magpi.cc 


Alla riga 9, controlla che il percorso corrisponda 
a quello dove hai scaricato il modello Mitsua 
Diffusion One. Nel nostro script di esempio, 
abbiamo lavorato con il nome utente "pi", 
altrimenti adatta la directory riportata nel 
tutorial. Premi CTRL+X per uscire e salvare 


quando richiesto. 
$ python mitsua_app.py 


Ti verrà chiesto di fornire un prompt per il 
modello: una descrizione dell'immagine che 
vorresti che producesse. Ti verranno quindi 
richiesti suggerimenti negativi: quello che non 
vuoi che l'immagine includa: un oggetto, un 
colore, una caratteristica come la sfocatura 0 
dita fuse o uno stile, ad esempio fotografia. 

La prima volta che esegui questo script, 
impiegherà più tempo. Se tutto è configurato 
correttamente, tuttavia, dovrebbe durare meno di 
15 minuti e produrrà un file di output con 
timestamp. 


Genera descrizioni di immagini 


La descrizione dell'immagine è incredibilmente 
importante nell'internet moderna. Il testo alternativo 
dell'immagine è indispensabile innanzitutto per gli utenti 
non vedenti e ipovedenti, ma anche per chiunque 
interagisca con il Web utilizzando testo, inclusi feed RSS 
e browser testuali come Lynx. 

Sebbene il testo alternativo realizzato a mano è meglio 
di qualcosa di automatizzato, non tutti trovano facile 
scrivere. E a volte potresti aver bisogno di uno 
strumento per descrivere rapidamente un'immagine per 
te per le tue ragioni. Questo progetto utilizza la stessa 
venv Python e la stessa struttura di directory che 
abbiamo impostato per il nostro progetto di generazione 
di immagini sicure da copyright e utilizza il modello di 
descrizione dell'immagine BLIP di Salesforce 
(Bootstrapping Language-Image Pre-training) 
(magpi.cc/blip). 

Se preferisci non utilizzare gli strumenti di machine 
learning dei giganti della tecnologia, preferirai evitare 
Salesforce. Un documento che descrive lo sviluppo di 
BLIP (magpi.cc/blippdf) indica che il suo allenamento è 
basato su coppie di immagini e testo alternativo 
recuperate dal web, poi filtrate per evitare didascalie 
‘rumorose’. Il processo di filtraggio e la limitazione della 
lunghezza delle didascalie, minimizza la probabilità di 
generare violazioni del copyright, ma la metodologia di 
allenamento dovrebbe essere presa in considerazione 
se intendi utilizzare le didascalie generate da BLIP. 

Inizieremo scaricando il modello e lo script image 
description. 
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09 Linee, please 
Poiché è istruito con materiale di pubblico 


dominio, principalmente da musei e gallerie d'arte, 
Wikimedia Commons e sottoinsiemi di pubblico 
dominio di vari siti di condivisione di immagini, 
Mitusa Diffusion One ha punti di forza e di 
debolezza specifici. 

Avrai più fortuna se gli fai produrre immagini 
alquanto convincenti di xilografie, incisioni, 
impressionismo e dipinti d'arte piuttosto che 
fotografie. Non siamo mai riusciti a avere una 
immagine davvero convincente di un gatto. 

Per ottenere i migliori risultati, abbiamo trovato 
utile nominare artisti e stili specifici. Visto che 
gran parte dei i suoi dati di addestramento 
provengono da collezioni di gallerie d'arte, 
vale la pena dare un'occhiata, ad esempio, all'Art 
Institute of Chicago’s collection (magpi.cc/aicpub) 
per trovare qualche ispirazione. 

In questo articolo, troverai esempi di stimoli e le 
immagini da essi prodotte. 


twinery.org 


$ cd «/Software/models 

$ git-1fs install 

$ git clone https://huggingface.co/ 
Salesforce/blip-image-captioning-base 

FG CIME 

$ git clone https://codeberg.org/ 
MightyOwlbear/blip-image-description-tool.git 
$ cd blip-image-description-tool 

$ nano captioner.py 


Controlla i percorsi per assicurarti che corrispondano 
alla posizione del tuo modello: se il tuo utente non si 
chiama "pi", dovrai cambiarli. Premi CTRL + X per salvare 
e uscire da nano. 


$ pyenv activate venv_diffusion 
$ python captioner.py 


Questa versione accetta solo indirizzi web per i suoi 
target immagine. Per testarlo, puoi usare il seguente 
URL di immagine: magpi.cc/gullsjpg. Ddovrebbe 
produrre una descrizione che reciti: "un gruppo di 
uccelli che volano nel cielo”. 


CI 
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mitsua-0pp.py CODICE COMPLETO 


SCARICA IL 


2024 


from diffusers import StableDiffusionPipeline 
from PIL import Image 
import datetime 


prompt = (“Descrivi l’immagine che vuoi: ‘“) 
negative_prompt = (“Descrivi i tratti da evitare - ad 
es. mani sfocate e fuse: “) 


# inserisci il percorso per Mitsua Diffusion One di seguito 
pipe = StableDiffusionPipeline.} (“/home/pi/ 
Software/models/mitsua-diffusion-one/”, 
low_cpu_mem_usage=True) 

pipe = pipe.to(“cpu”) 


image = (prompt, negative prompt=negative_prompt, 
num_inference_steps=31, width=400, height=400).images[0] 


# codificare il timecode di ogni immagine di output in 
mododo che non possano sovrascriversi 

created = datetime.datetime. () str 2 ( “XYX%mXAKHXMXS” ) 
image. °(‘“output-” + created + “.png”) 


SCARICA IL 
captioner.py CODICE COMPLETO 


import requests 

from PIL import Image 

from transformers import BlipProcessor, 
BlipForConditionalGeneration 


nserisci il percorso della directory del tuo modello in 


entrambe le righe seguenti 


processor = BlipProcessor.frc (“/home/pi/Software/ 


models/blip-image-captioning-base/”) 
model = BlipForConditionalGeneration. 
pi/Software/models/blip-image-captioning-base/”) 


img_url = (“Digita URL immagine JPG: “) 
raw_image = Image.open( 


requests. (img_url, stream=True).raw).con ( “RGB? ) 


inputs = essor(raw_image, return_tensors="pt?) 


out = model. (**inputs, max_new_tokens=1000) 
(processor. (out[0], skip _special_tokens=True)) 
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Top Tip 


htop 


Se hai uno schermo 
collegato al 
Raspberry Pi, puoi 
lanciare htop per 
monitorare i 
consumi di 
memoria e swap 
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Lucy 
Hattersley 


Lucy è capo 
redattrice di 7he 
MagPied è per lo 
più funzionale. 
magpi.cc 


Imparare Python: 
esplora le funzioni 
e crea una app CLI 


Diventiamo funzionali con Python, In questo tutorial imparerai come definire e 
chiamare le funzioni per evitare di scrivere lo stesso codice più e più volte 


Ti aiutano a scomporre i programmi Python 

in piccole parti gestibili che possono essere 
facilmente ripetibili. Rendono il tuo programma 
più modulare e più facile da capire. 

Ad alcuni piace pensare alle funzioni come 
taglia e incolla. Scrivi il codice una volta 
("definire" la funzione) e quindi incolli il codice 
("chiamare" la funzione). Anche se questo è utile 
per cominciare, le funzioni sono più potenti del 
taglia e incolla perché accettano input e 
forniscono output. 

In questo tutorial, esamineremo la definizione e 
la chiamata di funzioni con argomenti diversi. 
Quindi le utilizzeremo per creare una versione 
avanzata del programma ToDo dell'ultimo numero 
che salva una lista in un file e può essere eseguito 
da qualsiasi punto della CLI (Interfaccia della riga 
di comando). 


E Le funzioni sono il cuore 
pulsante di Python 


Le funzioni vengono definite utilizzando il 


Î e funzioni sono il cuore pulsante di Python. 


comando def, seguito dal nome della funzione e dalle 


parentesi (che contengono parametri opzionali da 


passare alla funzione). Un comando return 
opzionale rimanda tutti i risultati della funzione al 
programma principale. Qualcosa tipo: 


def funzione(parametri opzionali): 
# codice che fa cose 
return optional_return_value 


Il codice sotto una funzione è rientrato di quattro 
spazi. Questo fa sapere a Python che il codice 
rientrato viene eseguito quando viene utilizzata la 
funzione (nota come “chiamata di funzione”). 

Creiamo una funzione reale. Apri Thonny IDE e 
crea un nuovo file (salvalo come add_numbers.py. 
Ora inserisci queste righe: 


# Definisci una funzione che prende due numeri 
come argomenti e ritorna la loro somma 
def somma _numeri(num1, num2): 

totale = numl + num2 

return totale 


# Richiama la funzione con 2 e 3 come argomenti 
result = somma _numeri(2, 3) 
print(f’LA somma è: {result}”) 


magpi.cc Imparare Python: esplora le funzioni e crea una app CLI | Pagina tradotta da marcolecce per www.raspberryitaly.com e Maggio 


2024 


IT Tronny - tormenta 


è Be BD.o3->"»:- 


# ti 


todo pya 


Taorzy - bomefuo Dear ziodo; ® 


o:9 


Arport sys 
import os 


Bona dir = 03.path.exparduseri' ') 
todo file = os.path.foir[hora dir. "todo list.tat } 


dat load tasks(|: 
ns soth.esists(tedo_f(le]: 
mith openitodo filz, 

tasks = file.rosglinez1) 

ks = [task ctripfi for Task în tasks] 


det save tasksltacke} 
mita ossi tovo_11le, 

for task dn tasks 
file.write[M*{Lash}\n 

det ngi task(task]: 
tascs » losd tas 
tasks. apoend(tesk) 
Save tasxs(tasks} 


det vieu_tasks(l: 


shell 


Todo List: 
1, buy contee 


‘Qui viene utilizzata la Shell di Tnonny 
per eseguire il programma e 
visualizzare gli elementi nella nostra 
ToDo list 


La funzione di questo programma è di prendere 
due numeri e sommarli tra loro. Abbastanza 
semplice. Il programma è diviso in due parti. La 
prima parte è il def che definisce la funzione: 


def add _numbers(numi, num2) 


La seconda parte è la chiamata alla funzione, che 
chiede alla funzione add_numbers di sommare i 
numeri 2 e 3 e memorizzare la variabile total 
restituita in un'altra variabile chiamata result. 


result = add _numbers(2, 3) 


Infine, stampiamo la risposta utilizzando 
print(). Fai clic su Esegui in Thonny e dovresti 
vedere: "La somma è: 5" nella finestra della Shell 
sottostante. 

REPL Rispondi al mittente 

Una delle gioie di Python è che puoi interagire 
con i programmi nella Shell durante l'esecuzione 
grazie a REPL (Read-Eval-Print Loop). Fai clic 
sulla Shell e chiama direttamente la funzione con 
tutti i valori che desideri. 


add_numbers(6, 2) 


Gut Suppore 


Le varie funzioni del 
programma sono definite 
con il comando def 


© Il codice compreso in 
una funzione è rientrato 
di quattro spazi © 


Ciò restituisce 8 nella Shell. Mentre siamo in 
REPL dovremmo parlare di “ambito” o “ambito 
della funzione” in questo particolare concetto. In 
REPL puoi accedere e guardare direttamente le 
variabili del programma. Immettere result e la 
Shell visualizzerà "5" (il valore memorizzato dal 
programma nella riga 7 durante la chiamata della 
funzione, quando restituisce il valore totale). 

Tuttavia, inserisci total, e la Shell restituisce: 


Traceback (most recent call last): 
File “<pyshell>”, line 1, in <«module> 


Local Python 3 + Arcesbinipythont = 
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| Cosa Serve 


» Raspberry Pi 
» Raspberry Pi OS 


» Thonny IDE 


W La nostra 
introduzione alle 
funzioni prende due 
numeri e li somma 
tra loro 
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NameError: name ‘total’ is not defined def say _hello(name): 


, - RE rint(f’Ciao, {name}? 
Perché possiamo accedere alla variabile result, ma È ( i }°) 


non alla variabile total? La risposta è che le variabili 
all'interno della definizione (la parte rientrata sotto 
def) sono “locali”. Ciò significa che sono accessibili 
solo localmente all'interno di quella funzione. 
Una volta fuori dalla funzione e nel tuo 
__——r—r—- programma le variabili locali (come la nostra total) 
Top Ti p à non sono più necessarie, e in un ambiente di 
programmazione moderno come Python lo spazio di 
memoria viene pulito e riutilizzato. 
Questo è il motivo per cui è importante utilizzare 
return e memorizzare eventuali variabili o output 


Potremmo chiamare questa funzione usando: 


say_hello(“Alice”) 


Ma se vogliamo includere il predefinito anonimo 
lo aggiungiamo ai parametri usando name=”anon”. 
Inserisci il codice da say_hello.py. 


Parametri 


. def say _hello(name=”anon”): 
vs Argomenti 


print(f’Ciao, {name}!”) 


| parametri sono le della funzione che desideri utilizzare nel resto del 

variabili che sono codice. # Chiana la funzione con un nome specifico 
elencate all'interno say_hello(“Alice”) 

ua Variabili di default 

nella definizione Sollevi I bi Ila Shell: 1 

dell funzione olleviamo un altro problema nella Shell: la # Chiamata di funzione senza specificare un 
Gli argomenti sono chiamata alla funzione add_numbers() senza nome, utilizzando il valore predefinito “anon” 
i valori passati alla argomenti: say_hello() 


funzione quando add_numbers() 
viene chiamata. 


——_ _——_—__ Eseguilo e vedrai: 
La Shell restituisce un altro messaggio di errore: 
Ciao, Alice! 
TypeError: add_numbers() missing 2 required Ciao, anon! 
positional arguments: ‘numi’ and ‘num2’ 


La lettura del messaggio di errore ci dice cosa 
non funziona. "2 argomenti posizionali richiesti 
mancanti" (i nostri due numeri). 

Possiamo risolvere questo problema 
aggiungendo due numeri alla chiamata di 
funzione. Ma è anche possibile aggiungere 


Approfondire gli argomenti 

Uno dei limiti delle funzioni che abbiamo creato 
finora è che funzionano solo con un numero 
specifico di argomenti. Il nostro programma 
add_numbers.py somma solo due numeri tra 
loro,per esempio. 


Questa funzione 


iù un.valere parametri predefiniti nella definizione di funzione. . . n n . 
Cederna ; . E se volessi gestire più argomenti di importi 
p Supponiamo che stiamo creando un programma : . A . i 
caso manchi un a diversi? In questo caso è necessario conoscere il 
argomento. In che si rivolge alle persone per nome, ma permette E 
; . : ; arametro *args. 
questo esempio, loro di restare anonime. Potrebbe dire "ciao" P N 8 . . 
usa ‘anon’ invece i î . Questo è un tipo speciale di parametro che 
di un nome quando inseriscono il loro nome ; » nina . 
fomite gestisce più argomenti. Il "*" dice a Python di 
$ Me ina dira metterli in un tipo speciale di elenco chiamato 
CITTA 
o ra o os g0=* - “tupla”. Crea ed esegui il seguente programma, 
RR SR chiamandolo add_mult_numbers.py. 


det sep elle |niore"anner1 


def add_numbers(*args): 
total = @ 

for number in args: 

total += number 


ne Baiieli 


return total 


print(add_numbers(1, 2, 3)) # 6 
print(add_numbers(1, 2, 3, 4, 5)) # 15 


Eseguilo e la Shell restituisce 6 e 15. C'è anche un 
secondo parametro speciale chiamato **kvargs che 


uscite a è Aonmgeni — 
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gestisce più coppie chiave/valore (di cui non 
parleremo qui poiché le coppie chiave/valore 
sarebbero un argomento che distrae). Ci sono due 
valori da decomprimere, da qui i due asterischi. 


Ricorsione 


Fai un respiro profondo, perché è probabile che 

arrivi il mal di testa. La ricorsione è un concetto di 
programmazione relativamente complicato che, se 
ci pensi troppo, provoca rapidamente mal di testa. 

Il concetto generale è quello di una definizione di 
funzione contenente una chiamata a se stessa. 
Quando la funzione è chiamata, a sua volta, 
richiama un'altra versione di se stessa con un 
argomento modificato. 

Una semplice funzione ricorsiva è questa, quella 
che calcola la somma di tutti i numeri fino a un 
dato numero. Ad esempio, per trovare la somma di 
tutti numeri fino a 4, calcolerai 4 + 3+ 2+12= 10. 


def sum_up_to(n): 
# Caso base: se n è @, la somma fino a @ 
is just @ 
if n== 
return 0 
# Rcaso ricorsivo: n più la somma dei 
numeri fino a n-1 
else: 
return n + sum up_to(n-1) 


# Esempio d’utilizzo 
print(sum_up_to(4)) # Output: 10 


Questa funzione lavora prendendo il numero intero 
fornito (come 'n') e vi somma tutti i numeri inferiori 
ad esso. Lo fa aggiungendo n alla somma di n-1 
(chiamando sum_up_ to(n-1) per tutti i 
numeri finché non arriva a 0. 

Quindi risale la catena per produrre la somma 
finale. La ricorsione è una di quelle parti magiche di 
Python che incontrerai abbastanza frequentemente, 
e funziona, ma può essere piuttosto impegnativa 


< Questa funzione richiede 
molteplici argomenti 
utilizzando il parametro 
‘args invece di specificare i 
parametri individualmente 


Lana rim | aovcsmribnò = 


da visualizzare in mente. Non preoccuparti se non 
capisci tutto da questa semplice introduzione. Ci 
sarà tempo, in seguito, per comprenderla. 


Riga di comando 

Trasformiamo ciò che abbiamo imparato sulle 
funzioni in un programma utile. Espanderemo la 
ToDo list dell'esercizio precedente. Questa volta 

lo trasformeremo in un programma più dettagliato 
che viene eseguito dalla riga di comando. 

Inserisci il codice da todo.py in Thonny e salvalo 
sul disco. Apri una finestra del Terminale, vai alla 
stessa directory del programma todo.py ed esegui 
il programma per aggiungere, visualizzare ed 
eliminare le attività. 


+ Per aggiungere un task, usa: python todo.py 
add “Qui i dettagli del Task” 


* Per vedere tutti i tasks, usa: python todo.py view 

+ Per eliminare un'attività tramite il suo numero 
(come mostrato in view), usa: python todo.py 
delete 1 (dove 1 è il numero dell'attività da 


eliminare) 
Questa applicazione dimostra la gestione di base, 


l'analisi degli argomenti e le semplici operazioni 
CRUD (Create, Read, Update, Delete) in una 


Top Tip è 


Cos'è una tupla 


Una tupla è un tipo 
speciale di dati 
strutturati simile a un 
elenco, ma 
immutabile. Una 
volta creato, non 
può essere 
cambiato, solo 
utilizzato o 
cancellato. 


W Il programma Python 
todo.py eseguito dal 
terminale 
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© Abbiamo rimosso l'estensione .py spostando 
il file, Così possiamo eseguire il comando da 


qualsiasi punto del Terminale M 


Top Tip è 


Esegui da 
Thonny 


Puoi eseguire todo. 
py da Thonny con gli 
argomenti utilizzando 
il comando %Run nella 
Shell, ad esempio 
%Run todo.py view. 


Il programma ToDo 
finale in esecuzione 
direttamente come 
comando da qualsiasi 
Terminale 
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applicazione a riga di comando utilizzando Python. 
Sentiti libero di ampliarlo con più funzionalità, 
come le attività di modifica o categorizzazione. 


Scriviamolo 

Per trasformare todo.py in un'applicazione (0 
script) a tutti gli effetti, che puoi eseguire dalla 
riga di comando, segui questi passaggi. 

Aggiungi una riga "shebang" (#!) all'inizio del 
programma. Questo dice alla riga di comando quale 
versione di Python utilizzare. Assicurati che questa 
sia la primissima riga. 


#!/usr/bin/env python3 


Ora rendi eseguibile lo script. Apri una 
finestra del Terminale nella stessa directory di 
todo_list.py e inserisci quanto segue: 


cd /path/to/todo.py 
chmod +x ./todo.py 


Sostituisci /path/to/todo.py con la tua 
directory. Nel nostro caso: /home/lucy/ 
Documents/todo.py. 

Il comando chmod +x aggiunge diritti di 
eseguibilità al file, consentendo l'esecuzione del 
codice dalla riga di comando. 


Ora copia il file dalla tua directory di lavoro 
in una directory nel tuo PATH. Il path è un elenco 
delle posizioni in cui il terminale controlla i file 
quando esegui i comandi nella shell. Puoi vedere le 
posizioni attuali del PATH con: 


echo $PATH 


Le directory nel PATH sono elencate con i due 
punti “:” che le separano. Un luogo comune in cui 
spostare i file è /usr/local/bin (bin sta per 
“binario”). Copieremo qui il file todo.py (ti servirà 
usare sudo per ottenere l'autorizzazione): 


sudo cp ./todo.py /usr/local/bin/todo 


Nota che abbiamo rimosso l'estensione .py 
quando si sposta il file. È così che possiamo 
semplicemente eseguire il comando da qualsiasi 
punto del Terminale utilizzando "todo" come 
faremmo con qualsiasi altro comando come Is, 
Cp, 0 cat. Ora chiudi il Terminale e apri un'altra 
finestra o immetti il seguente comando per 
rinfrescare la shell. 


source »=/.bashrc 


Ora puoi eseguire il programma da qualsiasi 
luogo nel Terminale utilizzando solo il comando 
todo seguito da un'opzione: 


* todo add 
* todo view 
* todo delete 


Congratulazioni, ora hai un programma ToDo 
funzionante che salva l'elenco delle cose da fare in 
un file chiamato todo__list.txt nella tua directory 
home. Puoi visualizzare ToDo utilizzando l'opzione 
di visualizzazione delle cose da fare o utilizza 
cat ./todo_list.txt. 

C'è molto altro che puoi fare con il tuo 
programma ToDo. Soprattutto speriamo che ti sia 
piaciuto conoscere le funzioni e costruire un 
programma completo funzionale che si aggiunge al 
tuo Terminale di Raspberry Pi. 
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#!/usr/bin/env python3 


import sys # Importa il modulo sys per accedere 
agli argomenti da riga di comando 

import os # Importa il modulo os per verificare se 
un file esiste 


# Definisce il percorso del file 
home_dir = os.path.expanduser('»') 
directory dell’utente 
todo_file = os.path.join(home_dir, 
'todo_list.txt') # Costruisce il percorso completo 
def load_tasks(): 
# Carica i compiti dal file 
if os.path.exists(todo_file): 
with open(todo_file, 'r') as file: 
tasks = file.readlines() 
tasks = [task.strip() for task in 
tasks] 
else: 


# Rimuove il carattere di nuova riga 


tasks = [] # Ritorna una lista vuota se il 
file non esiste 
return tasks 


def save _tasks(tasks): 
#Salva i compiti nel file 
with open(todo_file, 'w') as file: 
for task in tasks: 
file.write(f"{task}\n"} 


def add_task(task): 
# Aggiungere un nuovo compito 
tasks = load_tasks() 
tasks.append(task) 
save_tasks(tasks) 


def view _tasks(): 
# Mostra tutti i compiti 
tasks = load _tasks() 
if tasks: 
print("Lista delle cose da fare:") 
for idx, task in enumerate(tasks, 


# Prende la home 


038. 
039. 
040. 
041. 
042. 
043. 
044. 
045. 
046. 
047. 
048. 
049. 
050. 
051. 
052. 
053. 
054. 


055. 


056. 
057. 
058. 
059. 
060. 
061. 
062. 
063. 
064. 
065. 
066. 
067. 
068. 
069. 
070. 


071. 
072. 


073. 
074. 
075. 


start=1): 


print(f"{idx}. {task}") 


else: 
print("La tua lista è vuotal") 


def delete _task(task_number): 
# Cancella un compito con il suo numero 
tasks = load _tasks() 
if ® < task_number <= len(tasks): 
del tasks[task_number - 1] 
save_tasks(tasks) 
print("Voce cancellata con successo.") 
else: 
print("Numero compito non valido.") 


def main(): 
# Check if the user has provided a command 
if len(sys.argv) < 2: # The first argument 
is the script name 
print("Sintassi: python todo.py [add/view/ 
delete] [task]") 
return 


command = sys.argv[1].lower() 

if command == ‘add': 
task = ' '‘.join(sys.argv[2:]) 
add_task(task) 
print("Voce aggiunta.") 


elif command == 'view': 
view_tasks() 
elif command == ‘delete’: 


if len(sys.argv) == 3: 
task_number = int(sys.argv[2]) 
delete task(task_number) 
else: 
print("Sintassi: python todo.py delete 
[task number]") 
else: 
print("Comando invalido. Usa add, view, 
o delete." ) 


if name "main __": 


main() 
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MUNE Magi | SPECIALE 


Custodie per 
aspberry Pi 5 


est di Gruppo 


Phil King prova alcune delle migliori 
custodie disponibili per Raspberry Pi 5 


essere ancora più figo, all'interno di una custodia intelligente. Ancora 

più importante, il case può anche aiutarlo a mantenere la scheda fresca 
sotto un carico di lavoro pesante, utilizzando cuscinetti termici, dissipatore di 
calore, ventola o una combinazione di tutti e tre. Per testare l'efficacia del 
raffreddamento, abbiamo eseguito uno stress test utilizzando tutti e quattro i 
core della CPU con il massimo di default di 2400 GHz. Abbiamo anche 
controllato il segnale Wi-Fi per vedere se interferivano con esso. Inoltre, 
abbiamo valutato la capacità di ciascun case — per il montaggio di un HAT ecc. 
— e l’accesso alle porte del Raspberry Pi 5. Chi è migliore? 


R aspberry Pi 5 è un fantastico computer a scheda singola, ma può 


n 70 | magpicc | Custodie Raspberry Pi 5 - Test di Gruppo | Pagina tradotta da Zzed per www.raspberryitaly.com cd Maggio 2024 


Maggio 


Case Ufficiale Raspberry Pi 5 
Raspberry Pi | magpi.cc/case 
10€ / 10$ 


Disponibile in rosso/bianco o nero, la custodia ufficiale è 
composta da tre sezioni di plastica che si agganciano a 
scatto, rendendo il montaggio semplicissimo. La sezione 
centrale comprende un inserto trasparente con ventola che 
si collega alla porta dedicata di Raspberry Pi 5. È incluso 
anche un piccolo dissipatore di calore per il SoC. 


Capacità: Rimuovendo l'inserto trasparente e la ventola 
dalla sezione centrale, è possibile montare un HAT. In 
alternativa, è possibile utilizzare un connettore di 
prolunga per sollevarlo sopra la ventola. 


Accessibilità delle porte: Tutte le porte laterali sono 
accessibili, così come il pulsante di accensione. La sezione 
centrale presenta un'ampia fessura per l'accesso ai pin 
GPIO quando il coperchio viene rimosso; potrebbe essere 
utilizzata anche per il passaggio dei cavi per videocamera 
o altri accessori. 


Raffreddamento: La ventola a velocità variabile viene 


aiutata dalle prese d'aria nella parte inferiore della custodia, 


oltre al dissipatore di calore del SoC. Funziona anche a 
coperchio chiuso, grazie a un foro circolare. Nei nostri test, 
ha impedito il throttling anche sotto carico intenso, ma 
altre custodie hanno ottenuto risultati migliori. 

Segnale Wi-Fi: Come ci si aspetterebbe, la custodia in 
plastica ha molto poco effetto sul segnale, che è rimasto 
forte. 

Verdetto 

Un design ben congegnato e versatile che copre la maggior 
parte degli usi. 


SPECIALE | MegPi MN 


ICE Tower CPU Cooler 


The Pi Hut | magpi.cc/icetower 
13€ /17$ 


Il suo design a torre dall'aspetto accattivante è arricchito 
da LED RGB che lo fanno brillare in vari colori. È davvero 
un case? Bene, ha una base in plastica, collegata tramite 
bulloni a due distanziali metallici alla sezione ventola/ 
dissipatore di calore nella parte superiore. Il montaggio è 
un po' complicato, ma non troppo. Il dissipatore di 
calore è collegato al SoC tramite un pad termico. 


Capacità: non potrai montare nessun HAT con questa 
grande ventola e dissipatore di calore piazzati sul Pi! 


Accessibilità delle porte: il design aperto significa accesso 
a tutte le porte e i pin GPIO non hanno ostacoli. 


Raffreddamento: la ventola montata verticalmente soffia 
aria sulle alette in alluminio del grande dissipatore, la 
cui base è collegato al SoC del Raspberry Pi 5 tramite un 
pad termico. Questo si traduce in eccellenti prestazioni di 
raffreddamento. Per default, la ventola non entra in 
funzione finché non raggiunge la temperatura di 60°C 
(cosa che non si è verificata durante i nostri test), ma 
potrebbe rivelarsi più utile se stai overclockando 
Raspberry Pi 5. 


Segnale Wi-Fi: la presenza di quel dissipatore di calore 
in metallo ha effetto sul segnale, ma non troppo. 


Verdetto 
Con il suo design e l'illuminazione insoliti, sembra molto 
bello... e offre un ottimo raffreddamento. 
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MEMI MisPi | SPECIALE 


VUIIZZA 
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Argon NEO 5 


Argon 40 | magpi.cc/argonneo5 
18€ /19$ 


Un design in tre pezzi — con due sezioni in alluminio 

e una base in plastica: il NEO 5 trasuda stile e qualità 

con la sua combinazione di colori rosso/nero e la 
sensazione di solidità. La sezione centrale è 
particolarmente impressionante, con una ventola e 

alette curve per favorire il raffreddamento. Il montaggio è 
assistito da una guida in un piccolo libretto. 


Capacità: Rimuovendo la parte superiore è possibile 
montare a un HAT con prolunga per il GPIO per 
sollevarlo sopra la ventola. C'è anche una versione 
speciale del case per NVMe. 


Accessibilità delle porte: la sezione centrale presenta vani 
per le porte principali, fotocamera/display, PCIe, UART, 
RTC e pin GPIO (con un'utile etichetta sul lato). 


Raffreddamento: l'effetto della ventola è aiutato dalle 
prese d'aria al centro della sezione e base, più un paio di 
pad termici per SoC e PMIC. Ciò si traduce in ottime 
prestazioni di raffreddamento. 


Segnale Wi-Fi: il case prevalentemente in metallo 
comporta una notevole riduzione della potenza e della 
qualità del segnale. 

Verdetto 

Un case elegante e di qualità con ottime prestazioni di 
raffreddamento. 


Case KKSB HAT 
The Pi Hut | magpi.cc/kksbhat 
13€ / 16$ 


Il case più alto del gruppo, è da 56 mm, ed è 
progettato per ospitare un Raspberry Pi 5 con sopra 
montato un HAT. La custodia in alluminio anodizzato 
non ha raffreddamento integrato, ma potresti 
aggiungere un Active Cooler o un dissipatore. C'è 
molto spazio e viene fornita una prolunga per il 
connettore GPIO se necessaria per sollevare 
leggermente un HAT. Il montaggio è complicato: è 
necessario rimuovere entrambi i pannelli laterali e far 
scorrere il Raspberry Pi, avvitarlo in posizione con 
piccole viti, quindi aggiungere un HAT in seguito. 


Capacità: Il grande spazio libero in altezza significa 
abbondante spazio per montare HAT sul Raspberry Pi. 
Puoi mettere cose dentro e fuori dalla custodia e fissarle 
in posizione, è complicato, però. Avremmo preferito un 
coperchio rimovibile. 


Accessibilità delle porte: le porte principali sono 
accessibili tramite appositi fori. Sono presenti slot per 
flat cable della fotocamera e PCIe. Dovrai rimuovere 
uno o entrambi i pannelli laterali per accedere alle altre 
porte. 


Raffreddamento: non è presente un raffreddamento 
integrato, ma il KKSB può essere utilizzato con un 
Active Cooler o con la maggior parte degli altri 
dispositivi di raffreddamento e dissipatori di calore. Le 
molte fessure nella custodia aiutano la ventilazione. 


Segnale Wi-Fi: forse sono tutte quelle fessure di 
ventilazione, ma... il segnale è difficilmente influenzato. 


Verdetto 
Non è il design più user-friendly e non ha raffreddamento 
integrato, ma buona una buona capienza. 


Maggio 
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SPECIALE | MagPi Va 


Passive Cooling Open CNC Case 
EDATEC | magpi.cc/opencnccase 
8€ / 8$ 


Raspberry Pi 5 è inserito tra le due sezioni del case, 
senza parti laterali. Ogni pezzo di alluminio scanalato 

è dotato di diversi cuscinetti termici per favorire il 
raffreddamento passivo, inclusi quelli per SOC, PMIC e 
modulo wireless. Le due sezioni del case sono assicurate 
con lunghi bulloni. 


Capacità: grazie al design aperto e all'accesso al 
connettore GPIO, puoi montare un HAT appena sopra la 
sezione superiore. 


Accessibilità delle porte: senza parti laterali, l'accesso 
alle porte è senza ostacoli, con ritagli per i pin GPIO, 
connettore PoE, Porte PCIe e per fotocamera/display, 
oltre a connettori UART e batteria RTC. 


Raffreddamento: il raffreddamento passivo altamente 
efficace è fornito dai numerosi pad termici e il case in 
alluminio scanalato. Mantiene il Raspberry Pi 5 fresco 
(37,8°C) anche con un carico di lavoro pesante. 


Segnale Wi-Fi: Il case in metallo comporta evidente 
riduzione della potenza e della qualità del segnale. 


Verdetto 
Ottimo accesso alle porte e prestazioni di 
raffreddamento passivo impressionanti. 


ABS Fan Case 

The Pi Hut | magpi.cc/absfancase 

12€ / 16$ 

Anche se non sembra il case più solido o pesante, ha due 
sezioni principali con abbondanti prese d'aria e puoi 
scegliere le strisce colorate da attaccare sul coperchio! Un 
il dissipatore di calore Armor Lite V5 con ventola si piazza 
sopra il Raspberry Pi 5 tramite cinque cuscinetti termici. 


Capacità: il dissipatore occupa un discreto spazio nel case. 
Potresti ancora montare un HAT con una prolunga per il 
connettore GPIO e senza coperchio. 


Accesso alle porte: le porte laterali principali sono 
accessibili tramite fori sagomati. Togliendo il coperchio è 
possibile accedere a tutte le altre. 


Raffreddamento: cinque pad termici collegano SoC, PMIC, 
RP1, RAM e modulo wireless con il dissipatore integrato 
con ventola. Considerando questo, le prestazioni di 
raffreddamento non sono state buono come ci 
aspettavamo, ma decenti. 


Segnale Wi-Fi: c'è qualche effetto sulla forza e qualità, 
probabilmente a causa del dissipatore di calore in metallo. 


Verdetto 
Prestazioni di raffreddamento mediocri in un case leggero. 
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BUMIINE Magfi | SPECIALE 


Pibow Coupe 5 
Pimoroni | magpi.cc/pibowcoupe5 
10€ / 10$ 


Come le precedenti edizioni del classico Pibow, questo 
case comprende più strati acrilici che devono essere 
assemblati per circondare Raspberry Pi e quindi fissati 
con quattro lunghi bulloni. È come fare un puzzle 3D. 
La parte superiore del Raspberry Pi è lasciata aperta, il 
che, in alcuni casi d'uso, può essere un vantaggio. 


Capacità: il design aperto della custodia ti consente 
di montare qualsiasi HAT tu voglia. 


Accessibilità delle porte: le porte USB ed Ethernet si 
trovano nella parte superiore della custodia, mentre i 
ritagli consentono l'accesso al resto. i pin GPIO sono 
completamente accessibili. 


Raffreddamento: non c'è un raffreddamento integrato, 
ma il Pibow può essere utilizzato con l’Active Cooler 0 
dissipatori standard. 


Segnale Wi-Fi: come ci si aspetterebbe da un case 


aperto, potenza e qualità del segnale sono molto buone. 


Verdetto 
Un case multicomponente, aperto, senza 
raffreddamento integrato, ma molto versatile. 
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Case FLIRC Raspberry Pi 5 
The Pi Hut | magpi.cc/flircrpi5 
11€ / 15$ 


Come i modelli precedenti, questa custodia FLIRC 
dall'aspetto smart è progettata per l'uso come media 
center. La sezione principale in alluminio funge anche 
da dissipatore di calore tramite un pad termico sul SoC 
di Raspberry Pi. C'è anche un mini pulsante di 
accensione. 

Capacità: non c'è spazio per un HAT all'interno della 
custodia. 


Accessibilità delle porte: le normali porte laterali sono 
tutte accessibili tramite ritagli, ma quelle interne — 
come PCIe e Pin GPIO — non lo sono. 


Raffreddamento: Il case in metallo agisce come un 
grande dissipatore di calore con un pad termico sul 
SoC, fornendo un raffreddamento passivo efficace. 


Segnale Wi-Fi: il case in metallo riduce un poco forza 
e qualità del segnale. 


Verdetto 
Una custodia smart e robusta per un media center. 


Case Passive Cooling CNC 
EDATEC | magpi.cc/cnccase 
18€ /19$ 


Come per l'Open CNC Case, i due pezzi della custodia sono 
in alluminio; qui mancano le scanalature, ma mantiene i 
pad termici. La parte inferiore ha anche fori per le porte 
sui lati. Il risultato è una custodia dall'aspetto elegante 
che si adatta perfettamente. 


Capacità: il vano per il connettore GPIO consente il 
montaggio di un HAT sopra la parte superiore del case. 


Accessibilità delle porte: i fori consentono completo 
accesso alle porte principali, insieme a pin GPIO, zoccoli 
PoE, PCIe e porte fotocamera/display e connettori per 
UART e batteria RTC. 


Raffreddamento: Come per la versione Open del case, il 
numerosi pad termici (per SoC, PMIC, wireless e 

parte inferiore) forniscono un raffreddamento passivo 
altamente efficace. 


Segnale Wi-Fi: racchiudere completamente Raspberry Pi 5 


in un box metallico ha un effetto negativo sul segnale WIFi. 


Verdetto 
Un case in metallo con un ottimo raffreddamento, ma il 
segnale Wi-Fi non è eccezionale. 
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SPECIALE | MegPi MN 


Argon ONE v3 


Argon 40 | magpi.cc/argononev3 
29€ / 30$ 


Il case più grande del gruppo, presenta una scheda figlia 
che si collega a lato del Raspberry Pi 5. Inoltre riporta le 
porte video e alimentazione su HDMI e USB-C full-size, il 
suo chip RP2040 gestisce il raffreddamento e 
l'alimentazione. C'è anche un ricevitore IR da utilizzare 
con un telecomando (fornito separatamente). Uno 
sportello magnetico rimovibile nella parte superiore del 
case protegge i pin GPIO e la loro etichetta descrittiva. 

È disponibile anche una versione NVMe del case. 


Capienza: Nonostante le dimensioni non è possibile 
montare un HAT standard all'interno della custodia. 


Accessibilità delle porte: USB ed Ethernet sono 
accessibili, così come alimentazione e due porte HDMI 
full-size. 


Raffreddamento: una ventola angolata nella parte 
superiore è supportata da due pad termici. È necessario 
installare uno script per controllare la ventola. Le 
prestazioni di raffreddamento non sono delle migliori, 
soprattutto sotto stress. 


Segnale Wi-Fi: la potenza e la qualità sono solo 
leggermente inferiori rispetto al case ufficiale. 


Verdetto 
Una custodia ricca di funzionalità, ideale per un media 
center o sistema desktop. 


BE Mesi | SPECIALE 


Confronto sul raffreddamento 
Abbiamo controllato la temperatura tipica della CPU al minimo 


e sotto stress (con tutti e quattro i core che funzionano a 2400 


MHz). 
A vuoto |Stressato 
(5) (°C) 
Case Ufficiale Raspberry Pi 5 47.2 65.9 
ICE Tower CPU Cooler CHL2 48.8 
Argon NEO 5 28.5 42.2 


Case KKSB HAT* = = 


Case EDATEC Passive Cooling 


Open CNC 25% 37.8 
Case ABS Fan 45.5 65.3 
Pibow Coupe 5* = = 

FLIRC 3394 49.9 
se EDATEC Passive Cooling 27.0 40.0 
Argon ONE v3 395 67.5 


* Nessun raffreddamento integrato. 
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Segnale Wi-Fi 


Abbiamo testato la forza e la qualità media del segnale Wi-Fi 
di Raspberry Pi 5, per ogni custodia. 


Case Ufficiale Raspberry Pi 5 


ICE Tower CPU Cooler 


Argon NEO 5 


Case KKSB HAT 


Case EDATEC Passive Cooling 
Open CNC 


Case ABS Fan 


Pibow Coupe 5 


FLIRC 


Case EDATEC Passive Cooling 
CNC 


Argon ONE v3 


Forza 


(dBm) 


-43 


=69 


=69 


-48 


=59 


257 


-46 


=69 


-65 


=50 


Qualità 
(%) 


96 


73 


73 


90 


73 


76 


983 


val 


64 


86 
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